## CLAIMS

What is claimed is:

| 1 | 1.      | A method, comprising:                                                   |
|---|---------|-------------------------------------------------------------------------|
| 2 |         | receiving a plurality of bytes in a first buffer having a size with a   |
| 3 | numb    | er of the plurality of bytes containing data;                           |
| 4 |         | determining a state of the plurality of bytes by a controller at least  |
| 5 | one cle | ock cycle before a rotation of the plurality of bytes; and              |
| 6 |         | predicting a rotation amount for the rotation of the plurality of       |
| 7 | bytes i | in a rotator based on the state.                                        |
| 1 | 2.      | The method of claim 1, wherein the rotation amount is predicted to      |
| 2 | be the  | size minus the number when the controller determines that a             |
| 3 | buffer  | , coupled to receive the plurality of bytes from the rotator, is empty. |
| 1 | 3.      | The method of claim 1, wherein the rotation amount is predicted to      |
| 2 | be the  | size minus the number when the controller determines that a             |
| 3 | buffer  | , coupled to output the plurality of bytes to the rotator, contains a   |
| 4 | start o | f packet signal.                                                        |
| 1 | 4.      | The method of claim 1, wherein the rotation amount is predicted to      |
| 2 | be the  | size minus the number when the first buffer contains a start of         |
| 3 | packet  | t signal, the buffer coupled to output the number of bytes to the       |
| 4 | rotato  | r.                                                                      |
| 1 | 5.      | The method of claim 1, wherein the first buffer is coupled to output    |
| 2 | the plu | urality of bytes to the rotator and a second buffer is coupled to       |
|   |         | Ī                                                                       |

| 3 | receive the plurality of bytes from the rotator, and wherein the rotation      |  |  |  |  |
|---|--------------------------------------------------------------------------------|--|--|--|--|
| 4 | amount is predicted to be zero when all of the plurality of bytes in the first |  |  |  |  |
| 5 | buffer are written to the second buffer.                                       |  |  |  |  |
| 1 | 6. The method of claim 1, wherein the first buffer is coupled to output        |  |  |  |  |
| 2 | the plurality of bytes to the rotator and a second buffer is coupled to        |  |  |  |  |
| 3 | receive the plurality of bytes from the rotator, and wherein the rotation      |  |  |  |  |
| 4 | amount is predicted to be zero when the first buffer contains an end of        |  |  |  |  |
| 5 | packet signal and a number of bytes in the first and second buffers is less    |  |  |  |  |
| 6 | than the size.                                                                 |  |  |  |  |

- 7. The method of claim 1, wherein the first buffer is coupled to output the plurality of bytes to the rotator and a second buffer is coupled to receive the plurality of bytes from the rotator, and wherein the rotation amount is predicted to be twice the size minus the number of bytes in the first and second buffers when a number of bytes in the first buffer and second buffers exceeds the size.
- 8. An apparatus, comprising:
  means for receiving a plurality of bytes having a size;
  means for determining a state of the plurality of bytes at least one
  clock cycle before a rotation of the plurality of bytes; and
  means for predicting a rotation amount for the rotation of the
  plurality of bytes based on the state.
- 9. The apparatus of claim 8, further comprising means for rotating the plurality of bytes based on the state.

| 1 | 10.        | The apparatus of claim 9, wherein the means for rotating               |  |
|---|------------|------------------------------------------------------------------------|--|
| 2 | comprises: |                                                                        |  |
| 3 |            | a rotation circuit coupled to receive an input and generate an         |  |
| 4 | outpu      | at; and                                                                |  |
| 5 |            | a multiplexer coupled to receive the input and the output of the       |  |
| 6 | rotati     | on circuit, the multiplexer to select between the input and the output |  |
| 7 | based      | l on a rotate amount control signal.                                   |  |
| 1 | 11.        | A method, comprising:                                                  |  |
| 2 |            | predicting a first number of bytes residing in a first buffer in a     |  |
| 3 | succe      | eding clock cycle; and                                                 |  |
| 4 |            | performing a calculation of a rotation amount of a second number       |  |
| 5 | of byt     | tes received from a second buffer based on the prediction, the         |  |
| 6 | calcul     | lation performed in a current clock cycle.                             |  |
| 1 | 12.        | The method of claim 11, wherein the first number is predicted to be    |  |
| 2 | zero.      |                                                                        |  |
| 1 | 13.        | The method of claim 12, wherein the first buffer is empty.             |  |
| 1 | 14.        | The method of claim 12, wherein the second buffer contains a start     |  |
| 2 | of pac     | cket signal.                                                           |  |
| 1 | 15.        | The method of claim 12, wherein all of the second number of bytes      |  |
| 2 | are w      | ritten to the first buffer.                                            |  |
| 1 | 16.        | The method of claim 11, wherein the first and second buffers have a    |  |
| 2 | size a     | nd wherein the first number is predicted to be the size minus the      |  |

| 3  | number of bytes in the second buffer when the second buffer contains a       |
|----|------------------------------------------------------------------------------|
| 4  | start of packet signal.                                                      |
| 1  | 17. The method of claim 11, wherein the first number is predicted to be      |
| 2  | twice the size minus a total number of bytes in the first and second buffers |
| 3  | when the total number of bytes in the first buffer and second buffers        |
| 4  | exceeds the size.                                                            |
| 1  | 18. The method of claim 16, wherein the size is 16.                          |
| 1  | 19. A data aligner, comprising:                                              |
| 2  | a first buffer coupled to receive a clock signal have a plurality of         |
| 3  | clock cycles;                                                                |
| 4  | a controller; and                                                            |
| 5  | a rotator coupled to the controller and the first buffer, the rotator        |
| 6  | comprising:                                                                  |
| 7  | a first rotation circuit coupled to receive an input and                     |
| 8  | generate a first output; and                                                 |
| 9  | a first multiplexer coupled to receive the input and the first               |
| 10 | output of the rotation circuit, the first multiplexer to select between      |
| 11 | the input and the first output based on a first rotate amount control        |
| 12 | signal receive from the controller, the first rotate amount control          |
| 13 | signal determined by predicting a number of bytes residing in the            |
| 14 | first buffer in a succeeding clock cycle.                                    |

| 1  |        | 20.                                                                         | The data aligner of claim 19,   | wherein the first buffer comprises a    |  |
|----|--------|-----------------------------------------------------------------------------|---------------------------------|-----------------------------------------|--|
| 2  |        | contro                                                                      | ol section coupled to receive a | buffer control signal from the          |  |
| 3  |        | controller.                                                                 |                                 |                                         |  |
|    |        |                                                                             |                                 |                                         |  |
| 1  |        | 21.                                                                         | The data aligner of claim 19,   | further comprising a second buffer      |  |
| 2  |        | couple                                                                      | ed to the rotator, wherein the  | nput is received from the second        |  |
| 3  |        | buffer                                                                      | ·. (                            | lack                                    |  |
|    |        |                                                                             |                                 |                                         |  |
| 1  |        | 22.                                                                         | The data aligner of claim 19,   | wherein the rotator further comprises:  |  |
| 2  |        |                                                                             | a second rotation circuit coup  | led to receive an output of the first   |  |
| 3  |        | multip                                                                      | plexer and generate a second o  | utput; and                              |  |
| 4  |        |                                                                             | a second multiplexer coupled    | to receive the second output of the     |  |
| 5  |        | secon                                                                       | d rotation circuit and the outp | ut of the first multiplexer, the second |  |
| 6  |        | multiplexer to select between the second output and the output of the first |                                 |                                         |  |
| 7  |        | multiplexer based on a second rotate amount control signal receive from     |                                 |                                         |  |
| 8  |        | the co                                                                      | ntroller, the second rotate amo | ount control signal determined by       |  |
| 9  |        | predic                                                                      | cting the number of bytes resid | ling in the first buffer in the         |  |
| 10 |        | succee                                                                      | eding clock cycle.              |                                         |  |
|    |        |                                                                             |                                 | <b>V</b>                                |  |
| ^  | 111    |                                                                             |                                 |                                         |  |
| 1  | 1900 - | )                                                                           |                                 |                                         |  |